/*
 * Copyright 1999-2018 Alibaba Group Holding Ltd.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.alibaba.druid.bvt.sql.oracle.pl;

import com.alibaba.druid.sql.OracleTest;
import com.alibaba.druid.sql.SQLUtils;
import com.alibaba.druid.sql.ast.SQLStatement;
import com.alibaba.druid.sql.visitor.SchemaStatVisitor;
import com.alibaba.druid.util.JdbcConstants;

import java.util.List;

public class Oracle_pl_basic_loop_0 extends OracleTest {
    public void test_0() throws Exception {
        String sql = "DECLARE\n" +
                "  x NUMBER := 0;\n" +
                "BEGIN\n" +
                "  LOOP\n" +
                "    DBMS_OUTPUT.PUT_LINE ('Inside loop:  x = ' || TO_CHAR(x));\n" +
                "    x := x + 1;\n" +
                "    IF x > 3 THEN\n" +
                "      EXIT;\n" +
                "    END IF;\n" +
                "  END LOOP;\n" +
                "  -- After EXIT, control resumes here\n" +
                "  DBMS_OUTPUT.PUT_LINE(' After loop:  x = ' || TO_CHAR(x));\n" +
                "END;";

        List<SQLStatement> statementList = SQLUtils.parseStatements(sql, JdbcConstants.ORACLE);
        assertEquals(1, statementList.size());
        SchemaStatVisitor visitor = SQLUtils.createSchemaStatVisitor(JdbcConstants.ORACLE);
        for (SQLStatement statement : statementList) {
            statement.accept(visitor);
        }

//        System.out.println("Tables : " + visitor.getTables());
//        System.out.println("fields : " + visitor.getColumns());
//        System.out.println("coditions : " + visitor.getConditions());
//        System.out.println("relationships : " + visitor.getRelationships());
//        System.out.println("orderBy : " + visitor.getOrderByColumns());

        assertEquals(0, visitor.getTables().size());

//        assertTrue(visitor.getTables().containsKey(new TableStat.Name("employees")));
//        assertTrue(visitor.getTables().containsKey(new TableStat.Name("emp_name")));

//        assertEquals(7, visitor.getColumns().size());
//        assertEquals(3, visitor.getConditions().size());
//        assertEquals(1, visitor.getRelationships().size());

        // assertTrue(visitor.getColumns().contains(new TableStat.Column("employees", "salary")));

        {
            String output = SQLUtils.toSQLString(statementList, JdbcConstants.ORACLE);
            System.out.println(output);
            assertEquals(
              "DECLARE\n"
                  + "\tx NUMBER := 0;\n"
                  + "BEGIN\n"
                  + "\tLOOP\n"
                  + "\t\tDBMS_OUTPUT.PUT_LINE('Inside loop:  x = ' || TO_CHAR(x));\n"
                  + "\t\tx := x + 1;\n"
                  + "\t\tIF x > 3 THEN\n"
                  + "\t\t\tEXIT;\n"
                  + "\t\tEND IF;\n"
                  + "\tEND LOOP;\n"
                  + "\t-- After EXIT, control resumes here\n"
                  + "\tDBMS_OUTPUT.PUT_LINE(' After loop:  x = ' || TO_CHAR(x));\n"
                  + "END;", //
              output);
        }
        {
            String output = SQLUtils.toSQLString(statementList, JdbcConstants.ORACLE, SQLUtils.DEFAULT_LCASE_FORMAT_OPTION);
            assertEquals(
              "declare\n"
                  + "\tx NUMBER := 0;\n"
                  + "begin\n"
                  + "\tloop\n"
                  + "\t\tDBMS_OUTPUT.PUT_LINE('Inside loop:  x = ' || TO_CHAR(x));\n"
                  + "\t\tx := x + 1;\n"
                  + "\t\tif x > 3 then\n"
                  + "\t\t\texit;\n"
                  + "\t\tend if;\n"
                  + "\tend loop;\n"
                  + "\t-- After EXIT, control resumes here\n"
                  + "\tDBMS_OUTPUT.PUT_LINE(' After loop:  x = ' || TO_CHAR(x));\n"
                  + "end;", //
              output);
        }
    }
}
